history
history
is a JavaScript library that lets you easily manage session history anywhere JavaScript runs. history
abstracts away the differences in various environments and provides a minimal API that lets you manage the history stack, navigate, confirm navigation, and persist state between sessions.
Docs & Help
Installation
Using npm:
$ npm install --save history
Then with a module bundler like webpack, use as you would anything else:
import histrory from 'history'
history.createHistory()
var createHistory = require('history').createHistory
The UMD build is also available on npmcdn:
<script src="https://npmcdn.com/history/dist/lib/index.js"></script>
You can find the library on window.History
.
Basic Usage
A "history" encapsulates navigation between different screens in your app, and notifies listeners when the current screen changes.
import history from 'history'
const history = history.createHistory()
const location = history.getCurrentLocation()
const unlisten = history.listen(location => {
console.log(location.pathname)
})
history.push({
pathname: '/the/path',
search: '?a=query',
state: { the: 'state' }
})
unlisten()
You can find many more examples in the documentation!
Thanks
A big thank-you to Dan Shaw for letting us use the history
npm package name! Thanks Dan!
Also, thanks to BrowserStack for providing the infrastructure that allows us to run our build in real browsers.